import { Component, OnInit } from '@angular/core';
import { JsonApiService } from "app/core/api/json-api.service"; //http请求配置引入
import {config} from '../../shared/smartadmin.config';

declare var $: any;
@Component({
    selector: 'sa-onlineMonitor',
    templateUrl: './onlineMonitor.component.html',
    styleUrls:['./onlineMonitor.component.css']
})
export class OnlineMonitorComponent implements OnInit {
	tableData:any[] = []; //table数据
	totalCount:number = 0; //分页总条数
	curPage:number = 1; //分页当前页
	pageSize:number = 10; //内置的分页每页条数
	searchKey:string = ''; //搜索keyword
	carList:any[] = [];
	companyId:string = '';
	deviceId:string = '';//设备ID
	startTime:string = '';//开始时间
	endTime:string = '';//结束时间
	linkState='1';
	carNumber:string = ''; //车牌号码
	selectedCompanyId:string = '';
	selectedCompanyName:string = '';
	
	constructor(private jsonApiService: JsonApiService) {}

	ngOnInit() {
		this.initDate().then(()=>this.load());
	}
	ngOnDestroy(){
		document.onclick = null;
	}
	//刷新
    refresh(){
    	this.load();
    }
	initDate(){
		var that = this;
		return new Promise(function (resolve, reject) {
			System.import('assets/js/datepicker/js/bootstrap-datetimepicker.min.js').then(
				()=>{
					System.import('assets/js/datepicker/locales/bootstrap-datetimepicker.zh-CN.js').then(()=>{
						
						$("#datetimepicker1").datetimepicker({//时间插件
							format: "yyyy-mm-dd hh:ii:ss",
						    language: "zh-CN",
						    autoclose: true,
						}).on("changeDate", function(e){
							var date = e.date;
							var time = common.getTimeMmss(date);
							$("#datetimepicker2").datetimepicker("setStartDate", time);
						});
						$("#datetimepicker2").datetimepicker({//时间插件
							format: "yyyy-mm-dd hh:ii:ss",
						    language: "zh-CN",
						    autoclose: true,
						}).on("changeDate", function(e){
							var date = e.date;
							var time = common.getTimeMmss(date);
							$("#datetimepicker1").datetimepicker("setEndDate", time);
						});
//						var date = new Date();
//						$("#datetimepicker2").val(common.getTimeMmss(date));//当前时间
//						date.setDate(date.getDate() - 7);//设置前一周
//						$("#datetimepicker1").val(common.getTimeMmss(date));
						resolve();
					});
				}
			);
		})

	}
	//查询
	table_search(){
		this.curPage = 1;
		this.searchKey = common.stringTrim(this.searchKey);
		this.load();
	}
	//  初始化加载list数据
	load() {
		this.startTime = $('#datetimepicker1').val();
		this.endTime = $('#datetimepicker2').val();
		let timeCheck=common.correctTimeParams(this.startTime,this.endTime,0);
		if(!timeCheck.status){
			this.jsonApiService.message(timeCheck.message);
			return;
		}
		let data = {
			pageSize:this.pageSize,
			nowPage:this.curPage,
			parameters:{
				companyId:this.selectedCompanyId,
				deviceId:this.deviceId,
				startTime:this.startTime,
				endTime:this.endTime,
				status:this.linkState,
				searchKey:this.searchKey
			}
		}
		let reqdata = 'gridPager='+JSON.stringify(data);
		
		
		this.jsonApiService.http("connectionStatus/connectionStatusForPage.html", reqdata).subscribe(result => {
			if(!result.isSuccess){
				this.jsonApiService.message(result.message)
			}
			
			for(let item of result.exhibitDatas){
				var timeNum=( this.getNumberTime(item.lastDate)-this.getNumberTime(item.onDate) ) / 1000;
				item.onlineTime=common.secondToDate(timeNum);
			}
			this.tableData = result.exhibitDatas;
			this.totalCount = result.recordCount;
		})
	}
	
	getNumberTime(str){
		
		var date = str.substring(0,19);    
	    var timestamp = new Date(date).getTime();
	    return timestamp;
		
	}
	
	
	//删除所选时间
	del_date(){
		this.startTime = '';
		this.endTime ='';
		$("#datetimepicker1").val('').change();
		$("#datetimepicker2").val('').change();
		$("#datetimepicker2").datetimepicker("setStartDate", null);
		$("#datetimepicker1").datetimepicker("setEndDate", null);
	}
	//分页回调
	paginate(e){
		this.curPage = e.page+1;
		this.pageSize = e.rows;
		this.load();
	}
	//公司选中回调
	companySelected(data){		
		this.selectedCompanyId = data.companyId;
		this.selectedCompanyName = data.companyName;
		this.deviceId = data.deviceId;
		this.carNumber = data.carNumber;
	}
}
